草庐IT

C++ 11:std::thread池化?

全部标签

c++ - 如何在 Xcode 中使用 c++ std::vector 元素类型和值查看?

在visualstudio中,当我使用c++std::vector调试代码时,我可以看到其中的所有元素,甚至可以深入到每个元素,不知何故,在Xcode5.1中,我可以看到这个选项我所看到的只是vector的迭代器。这是我尝试观察vector元素时在Xcode中看到的内容:我怎样才能在调试窗口中看到vector元素。 最佳答案 对我来说(Xcode6.0.1),这只发生在引用(&)类型上。尝试以下操作之一:添加自定义监视表达式*&strLineOfChrsVec(取消引用变量的地址)。进入堆栈并观察您传递给函数的原始变量。

c++ - Float 到 std::string 的转换和本地化

从float到std::string的转换是否会受到当前系统语言环境的影响?我想知道上面的代码是否可以在Germal语言环境下以“1234,5678”而不是“1234.5678”的形式产生输出,例如:std::stringMyClass::doubleToString(doublevalue)const{charfmtbuf[256],buf[256];snprintf(fmtbuf,sizeof(fmtbuf)-1,"%s",getDoubleFormat().c_str());fmtbuf[sizeof(fmtbuf)-1]=0;snprintf(buf,sizeof(buf)-1

c++ - 如何将数据类型的 std::map 制作为函数指针

我有这样的数据结构enumDataType_t{INT,FLOAT};structData{DataType_Ttype;void*min;void*max;};变量min和max取决于type的值。我想知道是否有办法创建std::map之类的std::mapmyMap;myMap[INT]=??//Hereshouldbeapointertoafunctionlikeint(*FcnPtr)(Datad,boolmin);myMap[FLOAT]=??//Hereshouldbeapointertoafunctionlikefloat(*FcnPtr)(Datad,boolmin);

c++ - 如何保护 C++03 和 C++11 的移动构造函数?

这类似于Whatdifferences,ifany,betweenC++03andC++11canbedetectedatrun-time?.但在这种情况下,我希望通过预处理器进行检测。我们应该如何守护moveconstructor(和moveassignment)当源代码同时用于C++03和C++11时?以下是否足够(movesemantics是所有C++编译器都采用的东西,因为它是必不可少的/核心功能)?#if(__cpluplus>=201103L)Foo(Foo&&other);#endif或者我需要深入了解编译器细节吗?如果我们需要编译器特定的宏,那么我们如何处理类似Visu

python - swig:如何使 QList<T> 可迭代,如 std::vector

我正在使用SWIG为我的qt应用生成Python绑定(bind)。我有几个地方使用QLists,我想集成SWIG库中的std::vector之类的QList(参见http://www.swig.org/Doc1.3/Library.html#Library_nn15)。这意味着:QList对象应该是可从python迭代的(=它们必须是可迭代的python对象)应该可以将python列表传递给采用qlist的函数...以及std::vector的SWIG库中列出的所有其他功能为此,我使用以下代码:https://github.com/osmandapp/OsmAnd-core/blob/

c++ - 为什么 std::advance 不返回结果迭代器?

目前,std::advance是这样设计的:templatevoidadvance(InputIt&it,Distancen);但是,我经常发现自己想要这样的东西:templateInputItadvance(InputItit,Distancen);那么,当前设计背后的基本原理是什么?这是出于某些性能考虑吗?请注意,std::next和std::prev会返回结果迭代器。 最佳答案 没有技术原因阻止它返回对输入值的引用,如果不使用返回值,任何合理的编译器都应该能够优化它。因此,如果他们愿意,他们可以那样做。我认为他们的选择从API

具有复制省略或 move 语义的 C++11 元组

我写了一个如下的函数:templatestd::tuple,T,T>f(){std::vectorp(1000);returnstd::make_tuple(std::move(p),10,10);}由于返回类型非常复杂,是否保证在c++11下编译器在构造结果时将应用复制省略或move语义,或者我必须明确地说出类似std::move(std::make_tuple(std::move(p),10,10))? 最佳答案 AFAIK复制省略始终是可选的。标准只是明确表示允许编译器进行此类优化,因为它改变了可观察到的行为,它并不强制执行。

c++ - Clang UBSAN 报告类型 'std::_Ios_Fmtflags' 的无效值

以下代码用clangUBSAN编译会崩溃#include#include#include#includetemplateinlinestd::stringfloatToString(Ti){printf("infloatToString\n");std::stringstreamss;ss.precision(6);ss用Clang3.6编译:$>clang++-3.6-fsanitize=undefined-fno-sanitize=float-divide-by-zero,vptr,function-fno-sanitize-recover-otesttest.cpp然后程序崩溃了

c++ - 指向结构的 std::vector 的指针

structStruct_t{intValue1;intValue2;};vectorStruct;Struct.resize(10,Struct_t());for(inti=0;i如何创建指向Struct[i]的指针?我想做的基本上是这样的,但我相信这可以做得更好:intvalue=6;Struct_ttemp=Struct[value],*s;s=&temp;s->Value1=42;s->Value2=6;主要目标是,我可以使用1行/函数轻松创建指向Struct[n]的指针。 最佳答案 到目前为止,提供的答案缺少房间里的大象。

C++11 - 从流中删除输入

当我的程序可能需要n行输入来解决下一个问题,然后再开始下一个问题时,我需要丢弃属于旧问题的所有输入行程序可以在读取所有输入之前解决它。当然,我可以简单地循环直到到达新问题的输入,但读取和存储所有这些数据可能会很昂贵。有没有办法简单地告诉输入流忽略下一个如此如此多的值? 最佳答案 voiddiscardLines(std::istream&in,std::size_tcount){if(!in)return;for(autoi=count;i!=0;--i)in.ignore(std::numeric_limits::max(),'\